import os
import time

from selenium.webdriver.support.wait import WebDriverWait

from base import log
from config import DIR_PATH


class Base:
    # 初始化方法
    def __init__(self, driver):
        log.info("正在初始化, driver对象：{}".format(driver))
        self.driver = driver

    # 查找元素方法
    def base_find(self, loc, timeout=10, poll=0.5):
        log.info("正在查找元素：{}".format(loc))
        return WebDriverWait(self.driver, timeout, poll).until(lambda x: x.find_element(*loc))

    # 点击方法
    def base_click(self, loc):
        log.info("正在调用点击元素：{}".format(loc))
        self.base_find(loc).click()

    # 输入方法
    def base_input(self, loc, value):
        log.info("正在调用输入元素方法：{} 输入内容：{}".format(loc,value))
        # 获取元素
        el = self.base_find(loc)
        # 清空
        el.clear()
        # 输入
        el.send_keys(value)

    # 获取文本方法
    def base_get_text(self, loc):
        log.info("正在调用获取元素信息方法：{}".format(loc))
        return self.base_find(loc).text

    # 截图方法
    def base_get_img(self):
        log.info("正在调用截图")
        img_path = DIR_PATH + os.sep + "img" + os.sep + "{}.png".format(time.strftime("%Y%m%d%H%M%S"))
        self.driver.get_screenshot_as_file(img_path)

    # 切换frame
    def base_switch_frame(self,loc):
        log.info("正在调用切换frame方法，切换对象：{}".format(loc))
        # 获取元素
        el = self.base_find(loc)
        # 执行切换
        self.driver.switch_to.frame(el)

    # 恢复frame
    def base_default_frame(self):
        self.driver.switch_to.default_content()